package cn.iocoder.yudao.module.erp.dal.dataobject.purchaseorder;

import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.*;

import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * 采购订单 DO
 *
 * @author maxuxu
 */
@TableName("erp_purchase_order")
@KeySequence("erp_purchase_order_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class PurchaseOrderDO extends BaseDO {

    /**
     * id
     */
    @TableId
    private Long id;
    /**
     * 销售订单id
     */
    private Long saleId;
    /**
     * 上游单据（销售订单）
     */
    private String saleNo;
    /**
     * 采购单号
     */
    private String billNo;
    /**
     * 采购日期
     */
    private LocalDateTime billDate;
    /**
     * 采购方
     */
    private String billContacter;
    /**
     * 采购联系人
     */
    private String billContacterName;
    /**
     * 采购电话
     */
    private String billContacterMobile;
    /**
     * 仓库id
     */
    private Long warehouseId;
    /**
     * 仓库名称
     */
    private String warehouseName;
    /**
     * 订单号
     */
    private String supplierOrderNo;
    /**
     * 供应商id
     */
    private Long supplierId;
    /**
     * 供应商名称（公司）
     */
    private String supplierName;
    /**
     * 供应商联系人
     */
    private String supplierContacterName;
    /**
     * 供应商联系电话
     */
    private String supplierMobile;
    /**
     * 总数量
     */
    private BigDecimal aggregateQuantity;
    /**
     * 总金额
     */
    private BigDecimal aggregateAmount;
    /**
     * 优惠金额
     */
    private BigDecimal discountAmount;
    /**
     * 优惠后总金额
     */
    private BigDecimal totalAmount;
    /**
     * 交付地址
     */
    private String deliveryAddress;
    /**
     * 物品信息（名称+数量）
     */
    private String goodsInfo;
    /**
     * 项目id
     */
    private Long projectId;
    /**
     * 项目名称
     */
    private String projectName;
    /**
     * 结算方式id
     */
    private Long settlementId;
    /**
     * 结算方式
     */
    private String settlementName;
    /**
     * 备注
     */
    private String remarks;
    /**
     * 附件
     */
    private String file;
    /**
     * 是否付款
     */
    private Boolean syncPay;
    /**
     * 是否入库
     */
    private Boolean syncIn;
    /**
     * 是否开票
     */
    private Boolean syncInvoice;

}